| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374 |
- "use client";
- import { GroupType, PrizeTypes } from "@/api/home";
- import Box from "@/components/Box";
- import CustomTabs from "@/components/Tabs";
- import { useRouter } from "@/i18n/routing";
- import { useSystemStore } from "@/stores/useSystemStore";
- import { getToken } from "@/utils/Cookies";
- import { Toast } from "antd-mobile";
- import clsx from "clsx";
- import { useTranslations } from "next-intl";
- import React, { FC, useState } from "react";
- import HomeGames from "./HomeGames";
- // import HomePrize from "./HomePrize";
- const buttonGroup: any = [
- // {
- // category_name: "sixth",
- // isHot: false,
- // url: "/freeGames",
- // locale: true,
- // lock: false,
- // isAnimation: true,
- // image: "/home/free.webp",
- // },
- // {
- // icon: "shipin",
- // category_name: "fourth",
- // isHot: false,
- // url: "/gameList?gameListFlag=10&type=1&bet_type=1&name=live",
- // locale: true,
- // lock: false,
- // image: "/home/live.png",
- // },
- // {
- // category_name: "replay",
- // isHot: false,
- // url: "/replayGames",
- // locale: true,
- // lock: false,
- // image: "/home/money.webp",
- // },
- // {
- // category_name: "history",
- // isHot: true,
- // url: "/gameList?pageType=1&name=History",
- // locale: true,
- // lock: false,
- // image: "/home/history.webp",
- // needLogin: true,
- // },
- // {
- // image: "/home/favorite.webp",
- // category_name: "Coletar",
- // isHot: false,
- // url: "/gameList?pageType=2&name=Favorite",
- // locale: true,
- // lock: false,
- // needLogin: true,
- // },
- ] as const;
- type TabItemType = (typeof buttonGroup)[number] & GroupType;
- const TabItem = ({
- item,
- active,
- onClick,
- }: {
- item: TabItemType;
- active?: boolean;
- onClick?: (item: TabItemType) => void;
- }) => {
- const t = useTranslations("ButtonGroup");
- const router = useRouter();
- const handler = (item: TabItemType) => {
- if (!item.locale) {
- onClick && onClick(item);
- return;
- }
- if (item.lock) {
- Toast.show("It is under development.");
- } else {
- if (item.needLogin && !getToken()) {
- router.push("/login");
- return;
- }
- router.push(item.url);
- }
- };
- const cls = clsx("pro-iconfont text-[.16rem]", item && item.icon ? `pro-${item.icon}` : "");
- // const cls2 = clsx("iconfont text-[.34rem]", `icon-${item.icon}`);
- return (
- <div
- className={clsx(
- "relative flex cursor-pointer items-center rounded-[.1rem] bg-[var(--main-background)] px-[.1rem] py-[.04rem]",
- !!active ? "text-[#fff]" : "text-[var(--textColor2)]"
- )}
- onClick={() => handler(item)}
- >
- <div className="relative z-[2] inline-block flex w-[.24rem] items-center justify-center">
- {!item.image && (
- <span
- className={clsx(cls, !!active ? "text-[#fff]" : "text-[var(--textColor4)]")}
- ></span>
- )}
- {item.image && (
- <img
- src={item.image}
- style={{ height: ".24rem" }}
- alt={item.url}
- className={clsx(item.isAnimation ? "animate-slow-bounce" : "")}
- ></img>
- )}
- </div>
- <div
- className={
- "relative z-[2] min-w-[0] flex-1 whitespace-nowrap px-[.02rem] text-center text-[0.1rem]"
- }
- >
- {item.locale ? t(item.category_name) : item.category_name}
- </div>
- {/* {item.isHot && (
- <img
- className={"absolute -top-[0.12rem] right-0 h-[0.21rem] w-[0.21rem]"}
- src=""
- alt=""
- />
- )} */}
- </div>
- );
- };
- interface Props {
- tabs: GroupType[];
- prize?: PrizeTypes[];
- }
- const Tabs: FC<Props> = (props) => {
- const { tabs, prize } = props;
- const router = useRouter();
- const { show_again_game, show_free_game } = useSystemStore((state) => {
- return {
- show_again_game: state.show_again_game,
- show_free_game: state.show_free_game,
- };
- });
- const [active, setActive] = useState<string | undefined>();
- const stickyRef = React.useRef<number>(0);
- const containerRef = React.useRef<number>(0);
- const handleRef = React.useRef<NodeJS.Timeout | null>(null);
- const newButtonGroup = buttonGroup.filter((item: any) => {
- if (item.url === "/freeGames" && show_free_game !== 1) {
- return false;
- }
- if (item.url === "/replayGames" && show_again_game !== 1) {
- return false;
- }
- return true;
- });
- const groupGames = React.useMemo(() => {
- return tabs[0]?.category;
- }, [tabs]);
- const tabData = React.useMemo(() => {
- return [...tabs, ...newButtonGroup].map((item, idx) => {
- const id = `${item.category_name}_${item.action_params}`;
- return {
- ...item,
- name: item.category_name,
- id,
- jump_id: item.action_params,
- headerRender: () => (
- <Box
- action={item.action_type}
- actionData={item.action_params}
- additional={{
- 6: () => {
- setActive(id);
- },
- 8: () => {
- tabClick();
- setActive(id);
- selectHandler(id);
- },
- }}
- pt={false}
- pr={false}
- pb={false}
- pl={false}
- >
- <TabItem
- item={item as TabItemType}
- active={`${id}` === active || (!active && idx === 0)}
- ></TabItem>
- </Box>
- ),
- };
- });
- // eslint-disable-next-line react-hooks/exhaustive-deps
- }, [tabs, active, newButtonGroup]);
- const tabClick = () => {
- if (handleRef.current) {
- clearTimeout(handleRef.current);
- handleRef.current = null;
- }
- handleRef.current = setTimeout(() => {
- handleRef.current = null;
- }, 1000);
- };
- const getTab = (id: string) => {
- let result = tabData.find((item: any) => {
- return item.id === id;
- });
- if (!result) {
- result = tabData[0];
- }
- return result;
- };
- React.useEffect(() => {
- initScroll();
- window.addEventListener("resize", () => {
- getContainerInfo();
- getStickyContainerInfo();
- });
- return () => {
- window.removeEventListener("resize", () => {
- getContainerInfo();
- getStickyContainerInfo();
- });
- };
- // eslint-disable-next-line react-hooks/exhaustive-deps
- }, []);
- const getStickyContainerInfo = () => {
- const dom = document.querySelector("#stickyContainer");
- if (dom) {
- stickyRef.current = dom.getBoundingClientRect().height;
- }
- };
- const getContainerInfo = () => {
- const dom = document.querySelector("#maincontainer");
- if (dom) {
- containerRef.current = dom.getBoundingClientRect().top;
- }
- };
- const initScroll = () => {
- const container = document.querySelector("#maincontainer");
- if (!container) {
- setTimeout(initScroll, 200);
- return;
- }
- container.addEventListener("scroll", doScorll);
- };
- const doScorll = () => {
- if (handleRef.current) return;
- let target = null;
- for (let i = 0; i < tabData.length; i++) {
- const element = tabData[i];
- if (element.action_type === 8) {
- const dom = document.querySelector(`#jump_${element.jump_id}`);
- if (dom) {
- const boundInfo = dom.getBoundingClientRect();
- if (!stickyRef.current) {
- getStickyContainerInfo();
- }
- if (!containerRef.current) {
- getContainerInfo();
- }
- if (boundInfo.top < stickyRef.current + containerRef.current + 10) {
- target = element;
- } else {
- break;
- }
- }
- }
- if (target) {
- setActive(target.id);
- }
- }
- // requestAnimationFrame(doScorll);
- };
- const selectHandler = (id?: string) => {
- if (!id) return;
- const toTab = getTab(id);
- if (toTab.action_type !== 8) return;
- const toDom = document.querySelector(`#jump_${toTab.jump_id}`);
- const container = document.querySelector("#maincontainer");
- if (!stickyRef.current) {
- getStickyContainerInfo();
- }
- if (!containerRef.current) {
- getContainerInfo();
- }
- if (toDom && container) {
- const boundInfo = toDom.getBoundingClientRect();
- const toScroll =
- container.scrollTop + boundInfo.top - containerRef.current - stickyRef.current;
- container.scrollTo({
- top: toScroll,
- behavior: "smooth",
- });
- }
- };
- return (
- <>
- <div
- className="homeTabsContainer sticky top-[0rem] z-[3] bg-[var(--primary1)] px-[.1rem] pb-[.05rem] pt-[.05rem]"
- id="stickyContainer"
- >
- <CustomTabs
- items={tabData as any}
- activeKey={active}
- onChanage={(value) => {
- setActive(value);
- }}
- ></CustomTabs>
- </div>
- {/* <div className="sticky top-[0rem] z-[3] bg-[var(--primary1)] px-[.1rem] pb-[.05rem] pt-[.05rem]">
- <Swiper
- slidesPerView={4.5}
- spaceBetween={4}
- // centeredSlides={true}
- // centeredSlidesBounds
- >
- {tabData?.map((group, index) => (
- <SwiperSlide key={index}>
- <Box
- action={group.action_type}
- actionData={group.action_params}
- additional={{
- 6: () => {
- setActive(index);
- },
- }}
- pt={false}
- pr={false}
- pb={false}
- pl={false}
- >
- <TabItem
- item={group as TabItemType}
- active={index === active}
- // onClick={(event) => selectHandler(event, index)}
- ></TabItem>
- </Box>
- </SwiperSlide>
- ))}
- <div className="absolute left-[0] bg-gradient-to-r from-[var(--gradient-left6)] to-[var(--gradient-right6)]">
- 2323
- </div>
- </Swiper>
- </div> */}
- {/* <HomePrize data={prize}></HomePrize> */}
- <HomeGames groupGames={groupGames} />
- </>
- );
- };
- export default Tabs;
|